## **UART Synchronization**

Busy-wait operation





# TM4C UART0 – Registers

|             | 31-12      | 11                 | 10   | 9    | 8       | 7-0<br>DATA |       |        | Name         |
|-------------|------------|--------------------|------|------|---------|-------------|-------|--------|--------------|
| \$4000_C000 |            | OE                 | BE   | PE   | FE      |             |       |        | UARTO_DR_R   |
|             | 31–3       |                    |      |      | 3       | 2           | 1     | 0      |              |
| \$4000_C004 |            |                    |      |      | OE      | BE          | PE    | FE     | UARTO_RSR_R  |
|             | 31–8       | 31-8 7 6 5 4 3 2-0 |      |      |         | 2-0         |       |        |              |
| \$4000_C018 |            | TXFE               | RXFF | TXFF | RXFE    | BUSY        |       |        | UARTO_FR_R   |
|             | 31–16 15–0 |                    |      |      |         |             |       |        |              |
| \$4000_C024 | DIVINT     |                    |      |      |         |             |       |        | UARTO_IBRD_R |
|             | 31–6       |                    |      |      | 5-0     |             |       |        |              |
| \$4000_C028 |            |                    |      |      | DIVFRAC |             |       |        | UARTO_FBRD_R |
|             | 31–8       | 7                  | 6-5  | 4    | 3       | 2           | 1     | 0      |              |
| \$4000_C02C |            | SPS                | WPEN | FEN  | STP2    | EPS         | PEN   | BRK    | UARTO_LCRH_R |
|             | 31–10      | 9                  | 8    | 7    | 6–3     | 2           | 1     | 0      | _            |
| \$4000_C030 |            | RXE                | TXE  | LBE  |         | SIRLP       | SIREN | UARTEN | UARTO_CTL_R  |

#### TM4C UART Setup

- UARTO operation
  - UART clock started in SYSCTL\_RCGCUART\_R
  - Digital port clock started in SYSCTL\_RCGCGPIO\_R
  - UARTO\_CTL\_R contains UART enable (UARTEN), Tx (TXE), and Rx enable (RXE)
    - set each to 1 to enable
    - UART disabled during initialization
  - UART1\_IBRD\_R and UART1\_FBRD\_R specify baud rate
    - bit rate = (bus clock frequency)/(16\*divider)
    - ex: want 19.2 kb/s and bus clock is 80 MHz
    - 80 MHz/(16\*19.2 k) = 26.04167 = 11010.000011<sub>2</sub>
    - Tx and Rx clock rates must be within 5% to avoid errors
  - GPIO\_PORTC\_AFSEL\_R to choose alternate function
  - GPIO\_PORTC\_DEN\_R Enable digital I/O on pins 1-0
  - GPIO\_PORTC\_AMSEL\_R no Analog I/O on pins 1-0
  - write to UARTO\_LCRH\_R to activate

## TM4C UART Programming

```
// Assumes a 80 MHz bus clock, creates 115200 baud rate
SYSCTL RCGCUART R |= 0x000000002; // activate UART1
 SYSCTL RCGCGPIO R |= 0x000000004; // activate port C
 UART1 CTL R &= ~0x00000001; // disable UART
 UART1 IBRD R = 43; // IBRD = int(80,000,000/(16*115,200)) = int(43.40278)
 UART1 FBRD R = 26; // FBRD = round(0.40278 * 64) = 26
 UART1 LCRH R = 0x00000070; // 8 bit, no parity bits, one stop, FIFOs
 UART1 CTL R |= 0x00000001; // enable UART
 GPIO PORTC AFSEL R |= 0x30; // enable alt funct on PC5-4
 GPIO PORTC DEN R |= 0x30; // configure PC5-4 as UART1
 GPIO PORTC PCTL R = (GPIO PORTC PCTL R&0xFF00FFFF) +0x00220000;
 GPIO PORTC AMSEL R &= ~0x30; // disable analog on PC5-4
```

## **UART Synchronization**

Busy-wait operation



UART Busy-Wait Send/Recv

```
// Wait for new input,
// then return ASCII code
uint8 t UART InChar(void) {
  while ((UART1 FR R\&0x0010) != 0);
  // wait until RXFE is 0
  return((uint8 t)(UART1 DR R&OxFF));
// Wait for buffer to be not full,
// then output
void UART OutChar(uint8 t data) {
  while ((UART1 FR R\&0x0020) != 0);
  // wait until TXFF is 0
  UART1 DR R = data;
```

